package 栈;

import java.util.Stack;

public class JZ30包含min函数的栈 {

    /**
     * 定义栈的数据结构，请在该类型中实现一个能够得到栈的最小元素的 min 函数在该栈中，
     * 调用 min、push 及 pop 的时间复杂度都是 O(1)。
     *
     * 示例:
     * MinStack minStack = new MinStack();
     * minStack.push(-2);
     * minStack.push(0);
     * minStack.push(-3);
     * minStack.min();   --> 返回 -3.
     * minStack.pop();
     * minStack.top();      --> [栈顶元素] 返回 0.
     * minStack.min();   --> 返回 -2.
     *  
     * 提示：
     * 各函数的调用总次数不超过 20000 次
     *  
     * 注意：本题与主站 155 题相同：https://leetcode-cn.com/problems/min-stack/
     */

    static class MinStack {

        Stack<Integer> sa;
        Stack<Integer> sb;

        public MinStack() {
            sa=new Stack<>();
            sb=new Stack<>();
        }

        public void push(int x) {
            sa.add(x);
            if(sb.empty()||sb.peek()>=x){
                sb.add(x);
            }
        }

        public void pop() {
            Integer aPop = sa.pop();
            if(aPop.equals(sb.peek())){
                sb.pop();
            }
        }

        public int top() {
            return sa.peek();
        }

        public int min() {
            return sb.peek();
        }
    }

}
